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CONFIGURABLE OUT-OF-ORDER 
DATA TRANSFER IN A COPROCESSOR INTERFACE 

by 

Lawrence Henry Hudepohl 
5 Darren Miller Jones 

Radhika Thekkath 
Franz Treue 

CROSS REFERENCE TO RELATED APPLICATIONS 

This application is related to U.S. Patent Application 

10 Serial No. (MIPS : 0104 . OOUS ) entitled 

"INSTRUCTION ISSUE GROUPS IN A COPROCESSOR INTERFACE"; U.S. 

Patent Application Serial No. 

(MIPS: 01075. OOUS) entitled "HIGHLY CONFIGURABLE CO- 
PROCESSOR INTERFACE"; and U.S. Patent Application Serial 

15 No. (MIPS: 0108. OOUS) entitled "A COPROCESSOR 

INTERFACE ENABLING COPROCESSOR- SPECIFIC BRANCHING"; each of 
which are incorporated herein by reference for all 
purposes . 

FIELD OF THE INVENTION 

20 This invention relates in general to the field of 

computer architecture, and more specifically to an 
interface for performing out-of-order data transfers 

1 
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between a central processor and one or more coprocessing 
devices . 

BACKGROUND OF THE INVENTION 

Early microprocessor based systems utilized a central 
5 processing unit, or CPU, which executed instructions, one 
at a time, in the order in which they were presented. 
These CPU's, due to their relative complexity, and 
associated cost, were typically designed to have universal 
application. That is, they were designed as general 

10 purpose CPU's. 

As the use of general purpose CPU's increased, so did 
the variety of application programs they were required to 
execute. In some instances, certain programs ran extremely 
slow because they required the CPU to perform complex 

15 calculations that were really beyond the scope of what it 
was intended to perform. An example of such calculations 
included floating point operations, such a multiply, 
divide, etc. 

To assist the CPU in executing such complex 
20 calculations, a floating point coprocessor was designed. 
The floating point coprocessor was essentially a second 
processor, external to the CPU, that was designed to 
perform certain complex operations such as a floating point 
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multiply, a floating point divide, etc, albeit much faster 
than the CPU. In operation, the CPU, when it was asked to 
perform a complex operation, would pass the operation over 
to the floating point coprocessor. The coprocessor would 
5 complete the task, and pass the results back to the CPU. 

Although the development of the floating point 
coprocessor enhanced the processing speed of certain 
applications, its cost kept it from being added to all 
systems. So, many computer systems were designed around a 

10 particular CPU (e.g., an 80286), and were designed to 
accommodate a dedicated floating point coprocessor (e.g., 
an 80287) , but the coprocessor was not provided with the 
system. If a user of the system executed the types of 
applications that could take advantage of the coprocessor, 

15 for an additional cost s/he could add the coprocessor to 
the system. 

Thus, while development of the coprocessor enhanced 
the performance of many CPU based systems, certain design 
problems arose. The first is that the coprocessor and the 
20 general purpose CPU must be tightly integrated, or designed 
together, to allow them to communicate together 
effectively. Operationally speaking, the CPU must be able 
to detect when a program wishes to use the coprocessor, it 
must pass those instructions over to the coprocessor, it 
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must provide the data to the coprocessor that corresponds 
to the instructions, and it must be able to receive results 
back from the coprocessor. In addition, the coprocessor 
must know whether the CPU has been interrupted by another 
5 process, and whether it still requires the result that it 
is calculating. One skilled in the art will appreciate 
that many other issues arise relating to communications 
that must occur between a CPU and a coprocessor. 
Consequently, since the CPU and the coprocessor have to be 
10 so tightly integrated, most coprocessors that have been 
designed are typically designed to work with a particular 
CPU. 

A problem that stems from the tight integration that 
is required between a CPU and coprocessor is that 

15 enhancement of the design of a particular CPU often 
requires a corresponding enhancement (or change) in the 
design of its associated coprocessor. For instance, an 
older coprocessor will typically not function with a newer 
CPU, and a newer coprocessor will typically not function 

2 0 with an older CPU. Thus, every time a CPU manufacturer 
wishes to introduce a new CPU, they must decide whether 
they want to develop a dedicated coprocessor that will work 
along with it. A decision to develop a coprocessor is a 
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very costly decision that ultimately must be supported by 
the marketplace. 

In addition, although the above-described history of 
the floating-point coprocessor provides a basis for 
5 understanding that the coprocessor must be designed with a 
specific CPU in mind, it does not address the scope of 
today's coprocessing problems. Certain present day 

application programs require complex, time-consuming 
calculations that are neither appropriate for a CPU, nor 

10 for a floating-point coprocessor; i.e., other types of 
coprocessor's are required to optimally execute these 
application programs. Such programs perform 3-D rendering 
for graphics applications, audio/signal processing etc. 
But graphics coprocessors, audio coprocessors, etc., that 

15 are required to perform these special -purpose programs 
typically must provide a particular interface (e.g., AGP) 
and thus these coprocessors will only inter-operate with 
CPU' s that are designed for that particular interface as 
well . 

20 From the viewpoint of a system designer, choosing a 

particular CPU for a particular application is increasingly 
difficult. The designer must anticipate the future needs 
of the system, utilizing tightly coupled CPU/coprocessor 
products, without being able to select the CPU and its 
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coprocessors separate from one another. For example, a 
designer may have requirements within an application that 
may be satisfied by choosing a relatively simple CPU along 
with a fairly complex graphics coprocessor. Regrettably, 
5 the complex coprocessor today is only compatible with an 
equally complex (and costly) CPU. Alternatively, the 
designer may have requirements within an application that 
may be satisfied by selecting a complex CPU along with a 
simple coprocessor. This combination is unfortunately not 

10 possible either because the complex CPU only interfaces to 
an equally complex (and costly) coprocessor. 

Therefore, what is needed is a configurable 
coprocessor interface that allows a variety of CPU's to be 
easily coupled to a variety of different coprocessors, 

15 without requiring that the coprocessors be designed 
specifically for those CPU's. 

What is also needed is a configurable coprocessor 
interface that allows both forward and backward 
compatibility between CPU's and coprocessors. That is, a 

20 coprocessor interface is desired that allows older, or 
legacy, coprocessors to be utilized with newer CPU's, and 
vice versa. 

Further, what is needed is a "standardized" 
coprocessor interface for which CPU's and coprocessors can 
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be designed. Such an interface would allow a system 
designer to select those specific CPU and coprocessor 
combinations that provide an optimum solution for the 
designer's needs, without regard to proprietary interface 
requirements . 

Finally, what is needed is a coprocessor interface 
that takes advantage of modern processing technology, such 
as multiple- issue of instructions, out-of-order data 
transfer, etc., without mandating that such technology 
exist in every device on the interface. 

SUMMARY 

The present invention provides a scalable and 
configurable coprocessor interface that distinguishes 
between instruction types that are transferred between a 
central processing unit (CPU) and a coprocessor. The 
configurable coprocessor interface also allows sequential 
or parallel transfer of differing instruction types to one 
or more coprocessor pipelines. In addition, the interface 
provides separate TO/FROM data buses between the CPU and 
the coprocessor to allow for simultaneous data transfer 
(in/out) between the CPU and the coprocessor. Furthermore, 
the interface provides for disassociation between 
instructions that are transferred, and data that is 
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transferred, to allow data elements to be moved in variable 
time slots with respect to their associated instructions. 
Moreover, the interface allows for out-of-order data 
elements to be transferred between the CPU and its 
5 coprocessors in an order that is not tied to the order that 
associated instructions are transferred (i.e., out-of-order 
data transfer) . Out-of-order data transfer according to 
the present invention does not require order tags to be 
associated with each data transfer. Rather, the interface 

10 keeps track of the relative order of outstanding 
instructions that require data for execution, and provides 
a relative order indicator along with each piece of data as 
it is transferred. In addition, condition code signaling 
is provided from the coprocessor to allow the coprocessor 

15 to evaluate CPU specific conditional instructions, and to 
inform the CPU as to whether or not it should execute the 
CPU conditional instructions. 

An embodiment of the present invention provides an 
interface for transferring data between a central 

20 processing unit (CPU) and a plurality of coprocessors. The 
interface includes an instruction bus and a data bus. The 
instruction bus transfers instructions to the plurality of 
coprocessors in an instruction transfer order, where 
particular instructions direct designated ones of the 
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plurality of coprocessors to transfer the data to/from the 
CPU. The data bus is coupled to the instruction bus. The 
data bus subsequently transfers the data, where data order 
signals within the data bus prescribe a data transfer order 
that differs from the instruction transfer order. 

In another aspect, the present invention provides a 
computer program product for use with a computing device, 
the computer program product has a computer usable medium 
that includes computer readable program code embodied 
thereon. The computer readable program code causes a 
coprocessor interface to be described that transfers data 
between CPU and a plurality of coprocessors. The computer 
readable program code has first program code and second 
program code. The first program code provides an 

instruction bus, where the instruction bus is configured to 
transfer instructions to the plurality of coprocessors in 
an instruction transfer order, and where particular 
instructions direct designated ones of the plurality of 
coprocessors to transfer the data to/from the CPU. The 
second program code provides a data bus. The data bus is 
configured to subsequently transfer the data, where data 
order signals within the data bus prescribe a data transfer 
order that is different from the instruction transfer 
order . 
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In a further aspect, the present invention provides a 
computer data signal embodied in a transmission medium. 
The computer data signal has computer-readable first 
program code and computer -readable second program code. 
The computer- readable first program code provides an 
instruction bus for transferring instructions to a 
plurality of coprocessors in an instruction transfer order, 
where particular instructions direct particular 
coprocessors to transfer data to/from a CPU. The computer- 
readable second program code provides a data bus for 
subsequently transferring the data, where data order 
signals within the data bus prescribe a data transfer order 
that differs from the instruction transfer order. 

In yet another aspect, the present invention provides 
a method for transferring data between a CPU and a 
plurality of coprocessors. The method includes 

transmitting instructions to the plurality coprocessors, 
each of the instructions directing a data transfer between 
the CPU and a specific coprocessor, where the transmitting 
is provided in a specific instruction order; and 
subsequently transferring the data in an order different 
from the specific instruction order. The transferring 
includes prescribing transfer of a data element 
corresponding to a specific outstanding instruction 
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relative to all outstanding instructions, the outstanding 
instructions being those instructions that have not 
completed a subsequent data transfer. 

Other features and advantages of the present invention 
will become apparent upon study of the remaining portions 
of the specification and drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIGURE 1 is a block diagram of a central processing 
unit (CPU) coupled to a coprocessor utilizing the 
coprocessor interface of the present invention. 

FIGURE 2 is a flow chart illustrating instruction flow 
through the CPU and coprocessor of Figure 1 . 

FIGURE 3 is a block diagram illustrating instruction 
dispatch signals between a CPU and a coprocessor utilizing 
the coprocessor interface of the present invention. 

FIGURE 4 is a timing diagram illustrating how 
instructions are dispatched on the coprocessor interface of 
the present invention. 

FIGURE 5 is a timing diagram illustrating how multiple 
instructions are dispatched to multiple issue groups via 
the coprocessor interface of the present invention. 

FIGURE 6 is a timing diagram illustrating how the 
coprocessor delays instruction dispatch from the CPU 
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utilizing busy signals on the coprocessor interface of the 
present invention . 

FIGURE 7 is a block diagram illustrating coprocessor 
to/from data transfer instruction signals between a CPU and 
a coprocessor utilizing the coprocessor interface of the 
present invention . 

FIGURE 8 is a timing diagram illustrating how data is 
transferred from a CPU to a coprocessor utilizing the 
coprocessor interface of the present invention. 

FIGURE 9 is a timing diagram illustrating how data is 
transferred from a coprocessor to a CPU utilizing the 
coprocessor interface of the present invention. 

FIGURE 10 is a block diagram illustrating coprocessor 
interface signals for: 1) coprocessor condition code 
checks; 2) CPU general purpose register values; 3) 
exception signal from a coprocessor to the CPU; and 4) 
instructions commit signaling from a CPU to a coprocessor, 
according to the present invention. 

FIGURE 11 is a timing diagram illustrating how a 
coprocessor responds to a CPU with condition code checks, 
according to the present invention. 

FIGURE 12 is a timing diagram illustrating exception 
handling between a CPU and a coprocessor utilizing the 
coprocessor interface of the present invention. 

12 
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FIGURE 13 is a timing diagram illustrating an 
instruction commit procedure by a CPU coupled to a 
coprocessor utilizing the coprocessor interface of the 
pr e s ent invent ion . 

DETAILED DESCRIPTION 

Referring to Figure 1, a portion of a computing system 
100 is shown. The computing system 100 provides a central 
processing unit (CPU) 102 coupled to memory 120 via a 
system bus 118. In general, the CPU 102 executes 

instructions retrieved from the memory 12 0, and interfaces 
with other devices 124 that are external to it via an I/O 
interface 122 attached to the system bus 118. 

The CPU 102 is also coupled to a coprocessor 110 
utilizing a coprocessor interface according to the present 
invention. The coprocessor 110 may be any type of 
coprocessor, but most commonly is a floating-point 
coprocessor, or a graphics (3-D) coprocessor. As will be 
more fully described below, with reference to Figure 2, the 
CPU 102 retrieves instructions from the memory 12 0, and 
determines whether the instructions are directed to it, or 
to the coprocessor 110. If the instructions are to be 
directed to the coprocessor 110, they are provided using 
the coprocessor interface of the present invention. 

13 
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Within the CPU 102 are a bus interface 104, a cache 
system 106, an execution core 108, and a coprocessor 
interface 112a. The bus interface 104 is coupled to the 
system bus 118 for retrieving and storing instructions and 
data, from and to the memory 12 0, and for communicating 
with the other devices 124. Data and instructions 
retrieved by the bus interface are provided to the cache 
system so that they may be immediately accessible to the 
execution core 108. The execution core 108 executes 
instructions provided to it by the cache system 106, 
operating on data that is either resident within the cache 
system 106, or retrieved by the bus interface 104. 

In one embodiment, the execution core 108 is split 
into two (or more) execution units (designated A & B) , each 
capable of executing instructions directed to the CPU 102 . 
That is, two (or more) instructions may be provided to the 
execution units A & B, within the execution core 10 8, for 
simultaneous execution . 

The execution core 108 is coupled to a coprocessor 
interface (COP interface) 112a. The COP interface 112a 
enables coprocessors such as floating point units (FPU's) 
and Graphics Engines to be tightly coupled to an integer 
processor core such as the execution core 108. In one 
embodiment, the COP interface 112a is designed to allow 

14 
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coprocessors to interface with various processor cores 
designed by MIPS Technologies, of Mountain View, 
California. 

The COP interface 112a includes many features, each of 
which will be further described below, with reference to 
Figures 3-14. More specifically, the COP interface 112a 
allows 32-bit or 64-bit data transfer between an integer 
core and a coprocessor. In addition, the COP interface 
112a supports one or more coprocessors, each of which may 
have one or more execution units. The COP interface 112a 
allows between 0 and 8 out-of-order data transfers. And, 
the COP interface 112 allows either single-issue of 
instructions, or multiple instruction issue, to one or more 
coprocessors, where each issue supports arithmetic and/or 
data transfers. Furthermore, as will be more particularly 
described with reference to Figure's 10, 11, and 13, the 
COP interface 112 allows for user defined exceptions, and 
coprocessor defined condition code interpretation. 
Finally, the COP interface 112a is designed to support 
coprocessor instructions defined in the MIPS32, MIPS64, 
MDMX and MIPS-3D architecture specifications available from 
MIPS Technologies, Inc.. Of course, one skilled in the art 
will appreciate that the novel features of the COP 
interface 112a are not restricted to data size, instruction 

15 
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set architecture, etc. Rather, the COP interface 112a is 
applicable to any interface between a CPU and a coprocessor 
where the design considerations include scalability, 
compatibility (both forward and backward) , and/or 
configurability. 

As shown in Figure 1, the COP interface 112a within 
the CPU 102 is coupled to a coprocessor 110 via coprocessor 
interface signal lines 116. Within the coprocessor 110 are 
a COP interface 112b and an execution unit 114. The COP 
interface 112b is similar to the COP interface 112a, but is 
designed to communicate from the coprocessor 110 to the CPU 
102. The execution unit 114 may either be a single-issue 
execution unit, or may be split into two (or more) 
execution units A and B for simultaneous execution of 
multiple coprocessor instructions. 

Operation of the computing system 100 will now be 
described with respect to the flow of instruction execution 
by reference to the flow chart 200 of Figure 2, to which 
attention is now directed. 

Instruction flow begins when instructions are fetched 
202 by the execution core 108. That is, a program counter 
(not shown) contains an address related to the next 
instruction to be executed. This address is provided to 
the cache system 106 for determination of whether the 

16 
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instruction is resident within the cache system 106. If it 
is not, the instruction is first fetched from the memory 
12 0, by the bus interface 104 and is provided to the 
execution core 108. Once the instruction is provided to 
the execution core 108, the instruction flow proceeds to 
the decode block 204. 

At decode block 204, the execution core decodes the 
instruction to be executed. That is, the decode block 
performs a variety of decoding functions, including 
determining whether the instruction is a branch 
instruction, and if so, predicting whether the branch will 
be taken, determining what operands are necessary for 
execution of the instruction, etc. Instruction flow then 
proceeds to decision block 206. 

At decision block 206, the execution core 108 
determines whether the instruction to be executed is an 
integer instruction to be executed by the execution core 
108, or whether the instruction is a coprocessor 
instruction to be executed by the execution unit 114. If 
the instruction is an integer instruction, instruction flow 
proceeds to block 208. Otherwise, the execution core 108 
provides the coprocessor instruction to the COP interface 
112a. The COP interface 112a then presents the coprocessor 
instruction, and any associated data for the instruction, 
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to the coprocessor 110 for execution. Instruction flow 
then proceeds to block 212. 

At block 2 08, the execution core 108 executes the 
integer instruction. Instruction flow then proceeds to 
block 210 where the result of the execution, if any, is 
written back into a register (or memory location) within 
the CPU 102. 

At block 212, the COP interface 112b receives the 
coprocessor instruction from the CPU 102 for execution. 
The coprocessor instruction, and its associated data, are 
provided to the execution unit 114 for execution. The 
result of the execution remains in the coprocessor 110 
until future instructions request that the result be 
transferred to the CPU 110. 

The above discussion, with reference to Figure's 1 and 
2 provides a general understanding of an interface between 
a CPU 102 and a coprocessor 110, utilizing the coprocessor 
interface 112 of the present invention. With the above in 
mind, particular operational specifics of the COP interface 
112 of Figure 1 will now be described with reference to 
Figures 3-14 by description of specific interface signals 
within the COP interface 112, and their operation with 
respect to such functions as instruction transfers, data TO 
transfers, data FROM transfers, etc. 

18 
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Instruction Transfer 

Instruction transfer refers to how coprocessor 
instructions are provided from a CPU to a coprocessor. 
Table 1 below provides a brief summary of some of the 
5 instruction transfer signals that are provided within the 
COP interface of the present invention. Illustration of 
how these signals operate will be further described below 
with reference to Figure's 3-6. 



TABLE 1 



Signal Name 


Dir 


Issue 
Group 


Description 


CP_ir_m[31:0] 


Out 


Comb, 
Arith, 
TF 


Coprocessor Instruction Word. Valid in the cycle before 
CPx_as_m, CPx_ts_m, CPx_fs_m is asserted. 


CPx_as_m 


Out 


Comb, 
Arith 


CoprocessorX Arithmetic Instruction Strobe. Asserted 
in the cycle after an arithmetic coprocessorX instruction is 
available on CP_ir_m. If CPx_abusy_m was asserted in 
the previous cycle, this signal will not be asserted. In any 
cycle, at most 1 of the following signals can be asserted at 
a time in a particular issue group. CPx„as_m, CPx_ts„m, 
CPx„fs_m. 


CPx„abusy_m 


In 


Comb, 
Arith 


CoprocessorX Arithmetic Busy. When asserted, a 
coprocessorX arithmetic instruction will not be dispatched. 
CPx_as_m will not be asserted in a cycle after the signal is 
asserted. 


CPxJs_m 


Out 


Comb, 
TF 


CoprocessorX to Str obe. Asserted in the cycle after a 
To COPx Op instruction is available on CP_ir_m. If 
CPx_tbusy_m was asserted in the previous cycle, this 
signal will not be asserted. In any cycle, at most 1 of the 
following signals can be asserted at a time in a particular 
issue group: CPx_as_m, CPx_ts_m, CPx_fs_m. 


CPx_tbusy_m 


In 


Comb, 
Arith 


To CoprocessorX Busy. When asserted, a To COPx Op 
instruction will not be dispatched. CPx_ts_m will not be 
asserted in a cycle after the signal is asserted. 



19 
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Signal Name 


Dir 


Issue 

a m 1 1 n 


Description 


CPx_fs„m 


Out 


Comb, 
TF 


CoprocessorX From Strobe. Asserted in the cycle after a 
From COPx Op instruction is available on CP_ir„m. If 
PPy fhn<;v m was asserted in the orevious cvcle, this 
signal will not be asserted. In any cycle, at most 1 of the 
following signals can be asserted at a time in a particular 
issue group: CPx_as_m, CPx_ts_m, CPx_fs„m. 


CPx_fbusy_m 


in 


Comb, 
Arith 


From CoprocessorX Busy. When asserted, a From 
COPx Op instruction will not be dispatched. CPx_fs_m will 
not be asserted in a cycle after the signal is asserted. 


CP_order_m|/.U| 


uut 


uomD, 
Arith, 
TF 


pAnrnracenr nicnnt**h OrriAr ^innifip^ thp nrnnram 

order of instructions when more than one instruction is 
issued in a single cycle. Each instruction dispatched has 
an order value associated with it. There must always be 
nnp in<strnrtion whosp order value is 0 Order values must 
increment by 1 when more than one instruction is issued in 
a cycle. Valid when CPx_as_m, CPx_ts_m, or CPx_fs_m 
is asserted. 


CP__VNs_m 


Out 


Comb, 
Arith, 

tf' 


Coprocessor Valid or Null Strobe. Asserted when a valid 
or null signal is available on CP_VN_m. 


CP_VN_m 


Out 


Comb, 
Arith, 
TF 


Valid or Nullify Coprocessor Instruction. When 
deasserted, the integer processor core is signaling that the 
instruction is valid, i.e., not nullified. When asserted, the 
integer processor core is signaling that the instruction is 
nullified. Valid when CP_VNs„m is asserted. 



Signal names in Table 1, and in the other tables that 
follow should be interpreted as follows: 

Signal names beginning in CP_ relate to signals from a 
CPU to any/all coprocessors coupled to the CPU. Signal 
names beginning in "CPx"__ are specific to particular 
coprocessors attached to the CPU. That is, if two 
coprocessors are attached to a CPU, two sets of signal 
lines will be provided by the coprocessor interface within 
the CPU. The first set of signal lines will begin "CP1_" , 
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the second set of signal lines will begin "CP2__" , etc. 
Rather than illustrate separate signals for CP1 and CP2 , 
they have been combined in the present discussion as "CPx" 
for purposes of clarity. Note: in one embodiment, within 
the context of the MIPS architecture, the only valid 
coprocessors are CP1 and CP2 . 

In addition, instruction types have been designated as 
arithmetic (a) , data TO coprocessor (t) , or data FROM 
coprocessor (f ) . So, arithmetic signal names include the 
letter "a", TO signal names include the letter "t" , and 
FROM signal names include the letter tt f " . By 
distinguishing between arithmetic, data to, and data from 
instructions, the coprocessor interface of the present 
invention allows coprocessors to disable certain types of 
instructions, within particular issue groups. 

The ending designation "_m" designates a particular 
issue group. The coprocessor interface of the present 
invention is extensible to support both single- issue and 
multi-issue cores and coprocessors. That is, a single 
issue CPU can support one or more multi-issue coprocessors. 
Alternatively, a mult i- issue CPU can utilize single or 
multi-issue coprocessors. Multi-issue support is achieved 
by duplicating certain signals of the coprocessor 
interface. Thus, if support of single- issue is desired, 
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only one set of signals is necessary, with the signal names 
ending in _m represented by "_0" . If multi-issue support 
is desired, then two sets of signals are necessary, with 
signal names ending in m represented by n _0" for the first 
set, and for the second set, etc. 

In one embodiment, all transfers between a CPU and a 
coprocessor are synchronously strobed. That is, a 

transfer, whether instruction or data, is only valid for 
one cycle (when a strobe signal is asserted) . In addition, 
there is no handshake confirmation of transfer, nor is 
there flow control relating to the transfer. Furthermore, 
except for data transfers, out-of-order transfers are not 
allowed. That is, all transfers of a given type, within 
the same issue group (to be further described below) , must 
be in instruction dispatch-order. However, ordering of 
different types of transfers for the same instruction is 
not restricted. 

Referring now to Figure 3, a block diagram 3 00 is 
shown illustrating particular instruction dispatch signals 
316 between a CPU 302 and a coprocessor 310 that were 
summarized above in Table 1. Each of the CPU 3 02 and the 
coprocessor 310 contains a COP interface 312 according to 
the present invention to allow instruction dispatch as 
follows . 
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Figure 4 provides a timing diagram 400 illustrating a 
simple case of instruction transfer. That is, three 
coprocessor instructions A, B & C will be transferred by 
the CPU 302 to the coprocessor 310. All of the signals 
shown in Figure 4 are synchronous with respect to a common 
clock signal generated by the CPU 3 02. In one embodiment, 
the clock signal is the core frequency signal of the CPU 
302 . 

At clock cycle 2, a coprocessor instruction A has been 
placed by the coprocessor interface 312 within the CPU 3 02 
on CP_ir_m[31:0] . This instruction is an arithmetic 
instruction, such as an ADD, MULTIPLY, DIVIDE, but may be 
another type of instruction defined within the arithmetic 
group. In addition, this instruction is in the issue group 
designated by "jn" . At the beginning of clock cycle 2, it 
is said that instruction A has been dispatched by the 
coprocessor interface 312. 

After an instruction is dispatched, additional 
information about that instruction must be transferred 
k etween the CPU 302 and the coprocessor 310. Such 
information includes the type of instruction (a, t, or f ) , 
an indication of which coprocessor the instruction is 
destined for (CP1, CP2 , etc.), and the issue group to which 
the instruction belongs (0, 1, 2 ...) . 
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At clock cycle 3, the coprocessor interface 312 
asserts the instruction dispatch strobe signal CPx_as_m to 
indicate to the coprocessor 310 that the instruction 
dispatched during the previous cycle should be used by the 
5 coprocessor as an active instruction, and that it was an 
arithmetic instruction. It is possible that the 

instruction dispatch strobe signal may be asserted in the 
same cycle as the instruction dispatch. 

Each such transfer can occur as early as one cycle 
10 after instruction dispatch, with no maximum limit on how 
late the transfer can occur. That is, only the dispatch 
portion of the coprocessor interfaces have flow control. 
In addition, the coprocessor interface 312 is designed to 
operate with coprocessors of any pipeline structure and 
15 latency. If the CPU 302 requires a specific transfer by a 
certain cycle, the CPU 3 02 must stall until the transfer 
has completed. In addition, all transfers are strobed. 
That is, independent of strobing, data is transferred in 
the cycle that the strobe signal is asserted. If the 
20 strobe signal is asserted for 2 cycles, then two transfers 
occur. 

At clock cycle 4, an instruction B is dispatched on 
signal lines CP_ir_m. 
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At clock cycle 5, an instruction C is dispatched on 
signal lines CP_ir_m. In addition, the coprocessor 

interface 312 asserts a CPx_ts_m signal to the coprocessor 
310 to indicate that the instruction dispatched on the 
5 previous cycle (instruction B) should be used as a TO 
coprocessor data instruction. 

At clock cycle 6, the coprocessor interface 312 
asserts a CPx_ts_m signal to the coprocessor 310 to 
indicate that the instruction dispatched in the previous 
10 cycle (instruction C) should be used as a TO coprocessor 
data instruction. 

At this point, three instructions have been 
transferred by the coprocessor interface 312 to the 
coprocessor 310: an arithmetic instruction A, and two TO 
15 coprocessor data instructions B and C. One skilled in the 
art should appreciate, however, that the instructions could 
have been dispatched to different coprocessors, if 
available, by utilizing separate strobe lines designated by 
w CPl__ts_jn" and "CP2__ts_m" , for example. 

2 o Instruction Valid or Nullify 

All instructions that are dispatched must be indicated 
as valid or nullified by the execution core after dispatch 
to the coprocessor 310. The valid or nullify transfer 
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signals within the coprocessor interface 312 must occur so 
that the coprocessor 310 knows when it can begin operation 
of subsequent operations that depend on the result of the 
current instruction. Validity or Nullification must be 
performed in an early stage of the coprocessor 310' s 
pipeline to insure that subsequent instructions can begin 
with correct operands. 

Referring to Figure 4, on clock cycle 4, the 
coprocessor interface 312 asserts strobe signal CP_Ws_m. 
This assertion corresponds to a validity/nullification 
transfer for instruction A. Also during clock cycle 4, the 
coprocessor interface 312 deasserts signal CP_VN__m to 
indicate that instruction A is valid and should not be 
nulled. 

On clock cycle 5, the coprocessor interface 312 
continues to assert strobe signal CP_VNs_m, and continues 
to deassert signal CP_VN_m to indicate that instruction B 
is valid. 

On clock cycle 8, the coprocessor interface 112 
asserts strobe signal CP_VNs_m corresponding to a validity 
or nullification transfer for instruction C. Also during 
clock cycle 8, the coprocessor interface 312 asserts signal 
CP W m to indicate to the coprocessor that instruction C 
should be nulled. 
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Thus, instruction validity or nullification continues 
for all instructions transferred between the CPU 3 02 and 
the coprocessor 310. There is no tag or other 

identification relating a validity or nullification signal 
5 on CP VJSMn with an instruction. Rather, since the 

instructions are in-order, the coprocessor interfaces 
within both the CPU 302 and the coprocessor 310 keep track 
of each transferred instruction, and do not allow an 
instruction to use operands generated by previous 

10 instructions until those previous instructions have 
received a CP_VNjn signal. In addition, if an instruction 
is nullified, no remaining transfers for that instruction 
will occur. If a transfer related to a nullified 

instruction occurs during the cycle of nullification, the 

15 transfer will be ignored. 

Instruction Ordering - Multiple Issue Groups 

Referring now to Figure 5, a timing diagram 500 is 
provided to particularly illustrate how instructions are 
transferred to multiple issue groups. In this timing 
20 diagram, it is presumed that the CPU 3 02 is a dual issue 
integer processor. The coprocessor 310 is also a dual 
issue coprocessor. The two issue pipes within the 

coprocessor 310 are designated as *_0 and *_1, 
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respectively. And, the coprocessor interfaces 312 of both 
the CPU 302 and the coprocessor 310 include interface 
signals corresponding to each of the two issue groups. 

In clock cycle 1, two instructions A and B are 
dispatched by the coprocessor interface 312 within the CPU 
302. Instruction A appears on signal lines CP__ir_0 
corresponding to the first issue group (or pipe within 
coprocessor 310) . Instruction B appears on signal lines 
CP_ir_l corresponding to the second issue group (or pipe 
within coprocessor 310) . 

During clock cycle 2, the coprocessor interface 312 
within the CPU 3 02 asserts strobe line CPl_as_0 to 
designate instruction A as an arithmetic instruction, to 
indicate to the coprocessor 310 that it is the target 
coprocessor for the instruction (i.e., CP1) , to indicate 
that the pipe for which instruction A is intended is the 
"0" pipe, and to complete the transfer of instruction A to 
the coprocessor. Additionally, the coprocessor interface 
312 within the CPU 302 asserts strobe line CPl_ts_l to 
designate instruction B as a TO coprocessor data transfer 
instruction, to indicate to the coprocessor 310 that it is 
the target coprocessor for the instruction (i.e., CP1) , to 
indicate that the pipe for which instruction B is intended 
is the "1" pipe, and to complete the transfer of 
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instruction B to the coprocessor. While not shown, it 
should be appreciated that instruction validity or 
nullification also occurs during later clock cycles, 
similar to that illustrated in Figure 4. 

Also during clock cycle 2, instruction order signals 
are presented by the coprocessor interface 312 to the 
coprocessor 310 to indicate the programming order of 
instructions A and B. That is, even though instructions A 
and B are presented in parallel to the two instruction 
pipes "0" and w l" within the coprocessor 310, an indication 
must be presented to the coprocessor 310 to indicate their 
original order with respect to the program. Such order 
indication is necessary to insure that the coprocessor 310 
resolves any dependencies between the instructions 
correctly. 

Thus, each issue group carries an order signal to 
indicate the order of the instruction in that issue group 
with respect to the others. Two signal groups are provided 
between the CPU 302 and the coprocessor 310, corresponding 
to the two execution pipes within the coprocessor 310. The 
first signal group is CP_order_0, corresponding to the tt 0" 
pipe. The second signal group is CP_order_l, corresponding 
to the "1" pipe. Thus, during clock cycle 2, at the time 
instructions A and B are transferred by the strobe signals, 
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the relative order of instructions A and B are designated 
by the two signal groups. More specifically, signal group 
CP_prder_0 indicates to the "0" pipe in the coprocessor 
310, that the instruction transferred to it, i.e., 
instruction A, is the first instruction, having a relative 
order of "0" . And, signal group CP_order_l indicates to 
the "1" pipe in the coprocessor 310 that the instruction 
transferred to it, i.e., instruction B, is the second 
instruction, having a relative order of "1". 

During clock cycle 4, two more instructions, C and D 
are dispatched by the coprocessor interface 312 within the 
CPU 302 to the coprocessor 310. Instruction C is 

dispatched on signal group CP__ir_l indicating that it is 
intended for the "1" pipe of coprocessor 310, and 
instruction D is dispatched on signal group CP_ir_0 
indicating that it is intended for the "0" pipe of 
coprocessor 310. Note, if more than two coprocessors are 
coupled to the coprocessor interface 312 of the CPU 3 02, 
then the transfer of the dispatched instructions is 
designated by the strobe signals associated with each of 
the coprocessors (e.g., CP1 vs. CP2) . 

During clock cycle 5, transfer of instruction C to 
pipe w l" of the coprocessor 310 is completed by assertion 
of strobe line CP1 as 1. Assertion of this strobe line 
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indicates that instruction C is an arithmetic instruction, 
and that it is directed to coprocessor CP1, in its "1" 
pipe. Also, transfer of instruction D to pipe "0" of the 
coprocessor 310 is completed by assertion of strobe line 
CPl_ts_0. Assertion of this strobe line indicates that 
instruction D is a TO coprocessor data transfer 
instruction, and that it is directed to coprocessor CP1, in 
its "0" pipe. 

Also during clock cycle 5, the relative order of 
instructions C and D are provided to the coprocessor 310 
via signal groups CP_order__0 , and CP_order_l . Signal group 
CP order__l designates that instruction C is the first 
instruction, by providing a relative order quantity of "0" 
to the coprocessor 310. Signal group CP_order__0 designates 
that instruction D is the second instruction, by providing 
a relative order quantity of "1" to the coprocessor 310. 

During clock cycle 6, instruction E is dispatched by 
the coprocessor interface 312 to the coprocessor 310. 

During clock cycle 7, instruction E transfer is 
completed by assertion of strobe line CPl_as_0 . This 
strobe line indicates that instruction E is designated for 
coprocessor CP1, that the instruction is an arithmetic 
instruction, and that it should be executed by the "0" 
pipe. Since instruction E was the only instruction 
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dispatched during clock cycle 6, its relative dispatch 
order is provided by signal group CP_order_0 as "0" . 

Also during clock cycle 7, instruction F is dispatched 
by the coprocessor interface 312 to the "1" pipe of the 
5 coprocessor 310. 

During clock cycle 8, instruction F transfer is 
completed by assertion of strobe line CPl_ts_l. This 
strobe line indicates that instruction F is designated for 
coprocessor CP1, that the instruction is a TO coprocessor 
10 data transfer instruction, and that it should be executed 
by the "1" pipe. Since instruction F was the only 
instruction dispatched during clock cycle 7, its relative 
dispatch order is provided by signal group CP_order_l as 
w 0" . 

15 Although not particularly illustrated, one skilled in 

the art should appreciate that by providing a 3 -bit signal 
group for each available issue group, up to 8 instructions 
may be dispatched at the same time, while still tracking 
their relative order for instruction execution. 

2 o Instruction Transfer - Coprocessor Busy 

Referring now to Figure 6, a timing diagram 600 is 
shown which particularly illustrates the operation of 
various busy signals available on the coprocessor interface 
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of the present invention. More specifically, each 

coprocessor that is coupled to a CPU may reach a point 
during execution of instructions such that it can't receive 
further instructions. Within the coprocessor interface of 
the present invention, busy signals are provided from the 
coprocessor to the CPU for each of the instruction types 
(a, t and f ) , for each available issue group. 

During clock cycle 1, an instruction A is dispatched 
on signal group CP_ir_0 . Also during cycle 1, a busy 
signal is asserted by coprocessor CPx on signal line 
CPx_tbusy__m. Assertion of this signal line indicates to 
the coprocessor interface 312 within the CPU 3 02 that 
coprocessor CPx cannot receive a TO coprocessor data 
instruction. 

During clock cycle 2, instruction A transfer is 
completed by assertion of strobe line CPx_as_m. That is, 
although the coprocessor 310 asserted a busy signal, the 
busy portion of the coprocessor was related to TO 
coprocessor data instructions, not to arithmetic 
instructions. So, instruction A dispatch is attempted and 
transferred. 

During clock cycle 3 instruction B is dispatched by 
the coprocessor interface 312. However, busy signals are 
being asserted by both the arithmetic and TO coprocessor 
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data transfer portions of the coprocessor 310. So, the 
coprocessor interface 312 within the CPU 302 continues to 
attempt dispatch of instruction B until the busy signal 
corresponding to its instruction type is deasserted. 
5 Also, during clock cycle 3, the arithmetic busy signal 

is deasserted. Since instruction B continues to be 
dispatched by the coprocessor interface 312, it appears 
that instruction B is not an arithmetic instruction. 

During clock cycle 4, the TO coprocessor data transfer 
10 busy signal is deasserted. Since instruction B continues 
for 1 more clock cycle, it appears that instruction B is a 
TO coprocessor data transfer instruction. 

During clock cycle 5, instruction B is dispatched. 
During clock cycle 6, instruction B transfer is 
15 completed by assertion of strobe CPx_ts_m. Also during 
clock cycle 6, instruction C is dispatched by the 
coprocessor interface 312 within the CPU 302. 

During clock cycle 7, instruction C transfer is 
completed by assertion of strobe signal CPx_fs_m, 
20 indicating that instruction C is a FROM coprocessor data 
transfer instruction. 

During clock cycle 8, a busy signal is asserted on 
signal line CPx_fbusy_m to indicate that during cycle 8, 
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the coprocessor 310 cannot receive another FROM data 
transfer instruction. 

What should be appreciated from the above is that at 
any time during execution of instructions by a coprocessor, 
5 should that coprocessor's resources become consumed, within 
a particular group (a, t, or f ) , the coprocessor can 
prevent further instructions from being transferred that 
are specific to the particular group, without affecting 
transfer of instructions to other groups. 

l o TolFrom Coprocessor Data Transfer 

To/From data transfer refers to how data, 
corresponding to previously transferred instructions is 
provided from a CPU to a coprocessor, and vice versa. 
Table 2 below provides a brief summary of some of the data 
15 transfer signals that are provided within the COP interface 
of the present invention. Illustration of how these 
signals operate will be further described below with 
reference to Figure's 7-9. 
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TABLE 2 



Signal Name 


Dir 


Issue 
Group 


Description 


To Coprocessor Data (For all To Coprocessor Operations) 


CP_tds_m 


Out 


Comb, 
TF 


Coprocessor To Data Strobe. Asserted when To COP 
Op data is available on CP_tdata_m. 


CP_torder_m[2:0] 


Out 


Comb, 
TF 


Coprocessor To Order. Specifies which outstanding To 
COP Op the data is for. Valid only when CP_tds_m is 
asserted. 


CP„torder_m 


Order 


3'b000 


Oldest outstanding to COP Op data 
transfer 


3'b001 


2 nd oldest To COP OP data transfer 


3'b010 


3 rd oldest To COP OP data transfer 


3'b011 


4 th oldest To COP OP data transfer 


3'b100 


5 th oldest To COP OP data transfer 


3'b101 


6 th oldest To COP OP data transfer 


3'b110 


7 th oldest To COP OP data transfer 


3'b111 


8 th oldest To COP OP data transfer 


CP_tdata_m[63:0] 


Out 


Comb, 
TF 


To Coprocessor Data. Data to be transferred to the 
coprocessor. For single word transfers, data is valid on 
CPJdata_m[31:0]. Valid when CP_tds_m is asserted. 
Note: In 32 bit data transfer size configuration, this bus is 
reduced to CP_tdata_rn[31:0]. 


CP_tordlim_m[2:0] 


Sin 


Comb, 
TF 


To Coprocessor Data Out-of-Order Limit. This signal 
forces the integer processor core to limit how much it can 
reorder To COP data. The value on this signal corresponds 
to the maximum allowed value to be used on 
CPJorder_m[2:0]. 


From Coprocessor Data (For all From Coprocessor Operations) 


CP_fds_m 


In 


Comb, 
TF 


Coprocessor From Data Strobe. Asserted when From 
COP Op data is available on CP_fdata_m. 


CP_forder_m[2:0] 


In 


Comb, 
TF 


Coprocessor From Order. Specifies which outstanding 
From COP Op the data is for. Valid only when CP_fds_m 
is asserted. 
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Signal Name 


Dir 


Issue 
Group 


Description 








CP_forder_m 


Order 


3'b000 


Oldest outstanding From COP Op data 
tran^fpr 

11 Gil IO 1 d 


3'b001 


2 nd oldest From COP OP data transfer 


3'b010 


3 rd oldest From COP OP data transfer 


3'b011 


4 th oldest From COP OP data transfer 


3'b100 


5 th oldest From COP OP data transfer 


3'b101 


6 th oldest From COP OP data transfer 


3'b110 


7 th oldest From COP OP data transfer 


3'b111 


8 th oldest From COP OP data transfer 


CP_fdata_m[63:0] 


In 


Comb, 
TF 


From Coprocessor Data. Data to be transferred from 
coprocessor. For single-word transfers, data must be 
duplicated on both CP_fdata_m[63:32] and 
CP„fdata_m[31:0]. Valid when CP_fds_m is asserted. 
Note: In 32 bit data transfer size configuration, this bus is 
reduced to CP_fdata_m[31:0]. 


CPJordlim_m[2:0] 


Sout 


Comb, 
TF 


From Coprocessor Data Out-of-Order Limit. This signal 
forces the coprocessor to limit how much it can reorder 
From COP Data. The value on this signal corresponds to 
the maximum allowed value to be used on 
CP_forder_m[2:0] 



Referring now to Figure 7, a block diagram 700 is 

shown illustrating particular data transfer signals 716 

between a CPU 702 and a coprocessor 710 that were 

5 summarized above in Table 2. Each of the CPU 702 and the 

coprocessor 710 contain a COP interface 712 according to 

the present invention to allow data transfer as follows. 

The coprocessor interface 712 within the CPU 702 

transfers data to the coprocessor 710 after a TO 
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coprocessor data transfer instruction has been dispatched. 
Only TO coprocessor data transfer instructions utilize this 
transfer. The coprocessor 710 must have a buffer available 
for this data after the To coprocessor data transfer 
instruction has been dispatched. If no buffers are 
available, the coprocessor 710 must prevent instruction 
dispatch by asserting CPx_tbusy_m. 

The coprocessor interface 712 allows out-of-order data 
transfers. That is, data can be sent by the CPU 7 02 to the 
coprocessor 710 in a different order from the order in 
which instructions were dispatched. When data is sent to 
the coprocessor 710, the CP__torder_m [2 : 0] signal group is 
also sent. This signal group tells the coprocessor 710 if 
the data word is for the oldest outstanding To coprocessor 
data transfer instruction, or the 2 nd oldest, or the 3 rd 
oldest, and so on. The coprocessor interface 712 allows up 
to 7 transfers to be outstanding while returning data for 
the next transfer. The coprocessor 710 can limit the 
extent of this reordering to match what its hardware 
supports, by using the CP_tordlim_m [2 : 0] signal group. 

To Coprocessor Data Transfer 

Referring to Figure 8, a timing diagram is shown 
illustrating data transferred from the CPU 702 to the 
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coprocessor 710 via the coprocessor interface 712 of the 
present invention . 

During clock cycles 2, 4, and 6, To coprocessor data 
transfer instructions A, B, and C are dispatched by the 
coprocessor interface 712. These instruction transfers are 
completed with the assertion of the strobe signal CPx_ts__m 
in the following respective clock cycles. 

During clock cycle 4, data corresponding to 
instruction A is presented on the signal group 
CP tdata_m [63 : 0] . In the same clock cycle the data 

transfer is completed by assertion of strobe signal 
CP_tds_m. In addition, the relative order of the data 
being transmitted on the signal group CP_tdata_m is 
provided by the signal group CP_torder_m [2 : 0] . In this 
instance, since there are no outstanding To coprocessor 
data transfer instructions, the relative order of the data 
is "0" . 

During clock cycle 7, data corresponding to 
outstanding To coprocessor data transfer instruction C is 
presented on signal group CP_tdata_m [63 : 0] . In addition, 
the data transfer is completed by assertion of strobe 
signal CP_tds_m. At this point, the data presented during 
clock cycle 7 is out-of-order with respect to its 
corresponding instruction C. That is, the data 
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corresponding to instruction B has not yet been presented. 
This fact is communicated by the CPU 702 via signal group 
CP_torder_m when it presents a value of w l" on its signal 
lines. When the coprocessor interface 712 within the 
coprocessor 710 sees the "1" value on this signal group, it 
understands that the data being received is to be 
associated with the 2 nd oldest outstanding data transfer 
instruction, which in this case is instruction C. 

During clock cycle 8, data associated with instruction 
B is presented on signal group CP_tdata__m. In addition, 
the data transfer is completed by assertion of strobe 
signal CP__tds_m. Finally, the relative order of the data 
being presented is provided via signal group CP_torder_m. 
In this instance, since the data associated with 
instruction A has already been provided, the data 
associated with instruction B is the oldest outstanding 
data. The coprocessor interface 712 within the CPU 702 
therefore presents a value of "0" on signal group 
CP__torder_m. 

Although not shown, what should be appreciated from 
the above is that out-of-order data transfers are 
independently tracked by the coprocessor interface 712 of 
the present invention, for each coprocessor 710 that is 



Docket MIPS: 0105. OOUS 

coupled to CPU 702, and for each issue group within each 
coprocessor 710. 

From Coprocessor Data Transfer 

The coprocessor interface 712 of the present invention 
5 transfers data from the coprocessor 710 to the CPU 702 
after a From coprocessor data transfer instruction has been 
dispatched. Only From transfer instructions utilize this 
transfer. The CPU 7 02 must have available buffers to allow 
the transfer to occur in the cycle after dispatch. The 
10 coprocessor interface 712 allows out-of-order transfer of 
data similar to that described above with reference to To 
coprocessor data transfers. 

Referring now to Figure 9, a timing diagram 90 0 is 
shown illustrating the out-of-order data tracking mechanism 
15 associated with From coprocessor data transfer 
instructions, according to the coprocessor interface 712 of 
the present invention. 

During clock cycles 2-4, and 6, From data transfer 
instructions A, B, C, and D are dispatched by the CPU 702 
20 to the coprocessor 710. During clock cycles 3-5, and 7, 
instructions A-D are transferred to coprocessor 710. 

During clock cycle 4, data associated with instruction 
A is presented by the coprocessor 710 to the CPU 702 via 
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signal group CP_fdata_m. The data transfer is completed by 
assertion of strobe signal CPx_fds_m during the same clock 
cycle. At this point, the data being presented corresponds 
to data instruction A, which is the oldest outstanding From 
data transfer. Therefore, the relative order of the data 
is provided by the coprocessor interface 712 within the 
coprocessor 710, indicated on signal group CP_forder_m as 
u 0" . 

During clock cycle 5, data associated with instruction 
C is presented by the coprocessor 710 to the CPU 702. The 
data transfer is completed by assertion of strobe signal 
CP_fds_m during the same cycle. At this point, the data 
being presented corresponds to instruction C, which is the 
2 nd oldest outstanding From data transfer, B data being the 
oldest. Therefore, the relative order of the data is 
provided by the coprocessor interface 712 within the 
coprocessor 710, indicated on signal group CP_forder_m as 

w -j^ " 

During clock cycle 7, data associated with instruction 
D is presented by the coprocessor 710 to the CPU 702. The 
data transfer is completed by assertion of strobe signal 
CP_fds_m during the same cycle. At this point, the data 
being presented corresponds to instruction D, which is the 
2 nd oldest outstanding From data transfer, B being the 
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oldest. Therefore, the relative order of the data is 
provided by the coprocessor interface 712 within the 
coprocessor 710, indicated on signal group CP_forder_m as 

w ^ 11 

5 During clock cycle 8, data associated with instruction 

B is presented by the coprocessor 710 to the CPU 702. The 
data transfer is completed by assertion of strobe signal 
CP_fds__m during the same cycle. At this point, the data 
being presented corresponds to instruction B, which is the 

10 oldest outstanding From data transfer. Therefore, the 
relative order of the data is provided by the coprocessor 
interface 712 within the coprocessor 710, indicated on 
signal group CP_f orderjn as "0" . 

Although not shown, what should be appreciated from 

15 the above is that out-of-order data transfers are 
independently tracked by the coprocessor interface 712 of 
the present invention, for each coprocessor 710 that is 
coupled to CPU 702, and for each issue group within each 
coprocessor 710. 

20 Condition Code Checking 

The coprocessor interface of the present invention 
provides signals for transferring the result of a condition 
code check from the coprocessor to the CPU. The 
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instructions that typically utilize condition codes include 
branch instructions and conditional move instructions. 
When these instructions are decoded by the CPU, they are 
dispatched to both the CPU and to the coprocessor. 

Table 3 below provides a brief summary of the 
condition code check signals that are provided within the 
COP interface of the present invention. Illustration of 
how these signals operate will be further described below 
with reference to Figure's 10-11. 



TABLE 3 



Signal Name 


Dir 


Issue 
Group 


Description 


CP_cccs_m 


In 


Comb, 
Arith 


Coprocessor Condition Code Check Strobe. Asserted 
when condition code check results are available on 
CP_ccc_m. 


CP_ccc_m 


In 


Comb, 
Arith 


Coprocessor Condition Code Check. Valid when 
CP_cccs_m is asserted. When asserted, the instruction 
checking the condition code should proceed with its 
execution (i.e., branch or move data). When deasserted, 
the instruction should not execute its conditional operation 
(i.e., do not branch and do not move data) 



For some instructions that are dispatched, a result is 
sent from the coprocessor to the CPU that indicates whether 
or not the CPU should execute that instruction. For 
branches, the coprocessor tells the CPU whether or not to 
branch. For example, a conditional branch executing in the 
CPU might require the evaluation of an operation whose 
operands occur within the coprocessor. In this instance, 
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the evaluation of the operation is performed entirely 
within the coprocessor, and providing the final condition 
codes to the CPU, rather than transferring the operands 
from the coprocessor to the CPU, and evaluating the result 
5 in the CPU. 

In the same way, if a conditional move instruction 
requires evaluation of an operation whose operands occur 
within the coprocessor, rather than transferring the 
operands from the coprocessor to the CPU, and then 
10 evaluating the result, evaluation of the operation is 
performed entirely within the coprocessor. That is, for 
conditional moves, the coprocessor tells the CPU whether or 
not to execute the move instruction. 

Thus, within the coprocessor interface of the present 
15 invention, it is the coprocessor that interprets certain 
conditional branch and conditional move instructions, and 
decides whether or not the CPU should execute them. Since 
evaluation of CPU branch and conditional move instructions 
are performed in the coprocessor, user-defined Boolean 
20 conditional operations are possible for conditional branch, 
and conditional move instructions, i.e., they need not be 
fixed a priori by the integer core. 

Referring now to Figure 10, a block diagram 1000 is 
provided that illustrates the condition code signals 1016 



Docket MIPS : 0105 . OOUS 

transmitted by a coprocessor 1010 to a CPU 1002 via a 
coprocessor interface 1012. Operation of the condition 
code signals will now be described with reference to Figure 
11, to which attention is now directed. 
5 Figure 11 provides a timing diagram 1100 illustrating 

execution of three instructions, A, B, and C by the CPU 
1002 and coprocessor 1010. Instruction A is dispatched by 
the CPU 1002 during clock cycle 2, and transfer is 
completed to the coprocessor 1010 by assertion of 
10 arithmetic strobe CPx_asjn during clock cycle 3. As 
mentioned above, instruction A also proceeds down the 
pipeline of the CPU 1002. 

During clock cycle 4, the coprocessor interface 1012 
of the coprocessor 1010 asserts the condition code strobe 
15 CP cccs_m to indicate that the condition code resulting 
from evaluation of instruction A is available on condition 
code signal line CP_ccc_m. In this instance, CP_ccc_m is 
deasserted indicating to the CPU 1002 that it should not 
perform the operation specified by instruction A (either a 
20 conditional branch, or a conditional move operation) . 

Also during clock cycle 4, instruction B transfer is 
completed to the coprocessor 1010 by assertion of the 
arithmetic strobe CPx_as_m. 
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During clock cycle 5, the coprocessor interface 1012 
of the coprocessor 1010 asserts the condition code strobe 
CP_cccs_m to indicate that the condition code resulting 
from evaluation of instruction B is available on condition 
code signal line CP_ccc_m. In this instance, CP_ccc_m is 
Reasserted indicating to the CPU 1002 that it should not 
perform the operation specified by instruction B (either a 
conditional branch, or a conditional move operation) . Also 
during clock cycle 5, instruction C is dispatched by the 
CPU 1002 . 

During clock cycle 6, instruction C transfer is 
completed to the coprocessor 1010 by assertion of the 
arithmetic strobe CPx_as_m. 

During clock cycle 8, the coprocessor interface 1012 
of the coprocessor 1010 asserts the condition code strobe 
CP_cccs_m to indicate that the condition code resulting 
from evaluation of instruction C is available on condition 
code signal line CP_cccjn. In this instance, CP_ccc_m is 
asserted indicating to the CPU 1002 that it should perform 
the operation specified by instruction C (either a 
conditional branch, or a conditional move operation) . 
Although not shown, it should be appreciated the "_m" 
suffix on the condition code signal lines indicate that 
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condition codes exist for each issue group within a 
coprocessor' s interface . 

GPR Data 

The coprocessor interface of the present invention 
5 provides signals for transferring the results of a check on 
a register within the CPU 1002 to the coprocessor 1010 , for 
particular coprocessor instructions. These instructions 
include the MOVN.fmt and MOVZ.fmt instructions of the MIPS 
Instruction Set Architecture (ISA) . Other instructions 
10 supported include the ALNV.PS and ALNV.fmt instructions. 
When these instructions are dispatched to the coprocessor 
1010, they are also dispatched to the CPU 1002. 

Table 4 below provides a brief summary of the GPR 
signals that are provided within the COP interface of the 
15 present invention. 
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TABLE 4 



Signal Name 


Dir 


Issue 
Group 


Description 


CPx_gprs_m 


Out 


Comb, 
Arith 


GPR Strobe. Asserted when additional general-purpose 
register information is available on CPx_gpr_m. 


CPx_gpr_m[3:0] 


Out 


Comb, 
Arith 


GPR Data. Supplies additional data from the CPU general 
purpose register file. CPx_gpr_m[2:0] is valid when 
CPx_gprs_m is asserted and only for ALNV.PS and 
ALNV.fmt instructions. CPx_pgr_m[3] is valid when 
CPx_gprs_m is asserted and only for MOVN.fmt and 
MOVZ.fmt instructions. 


CPx_gpr_m[2:0] 


RS 

(Valid only for ALNV.PS, 
ALNV.fmt) 


Binary encoded 


Lower 3bits of RS register contents 




CPx_gpr_m[3] 


RT Zero Check 
(Valid only for MOVN.fmt, 
MOVZ.fmt) 


0 


RT!=0 


1 


RT==0 



Coprocessor Exception Found 

The coprocessor interface of the present invention 
5 provides signals for transferring exception information 
from the coprocessor to the CPU. The exception found 
transfer is used to signal whether an instruction caused an 
exception in the coprocessor 1010, or not. 

When a coprocessor instruction causes an exception, 
10 the coprocessor 1010 signals this to the CPU 1002 so that 
it can start execution from the exception vector. 



Docket MIPS : 0105 . 00US 

Table 5 below provides a brief summary of the 
exception found signals that are provided within the COP 
interface of the present invention. Illustration of how 
these signals operate will be further described below with 
5 reference to Figure's 10 and 12. 



TABLE 5 



Signal Name 


Dir 


Issue 
Group 


Description 


CP_excfs_m 


In 


Comb, 
Arith, 
TF 


Coprocessor Exception Found Strobe. Asserted when 
coprocessor exception signaling is available on 
CP_excf_m. 


CP excf m 


In 


Comb, 
Arith, 
TF 


Coprocessor Exception Found. When deasserted, the 
coprocessor is not causing an exception. When asserted, 
signifies that the coprocessor is causing an exception. The 
type of exception is encoded on the signal 
CP_exccode_m[4:0]. Valid when CP__excfs_m is asserted. 


CP_exccode_m[4:0] 


In 


Comb, 
Arith, 
TF 


Coprocessor Exception Code. Valid when CP_excfs_m 
is asserted and CP_excf_m is asserted. 








CP_exccode_m 


Exception 










5'b01010 


Reserved Instruction Exception 










5'b01 111 


Floating Point Exception 










5'b10000 


Available for implementation specific 
use 










5'b10001 


Available for implementation specific 
use 










5'b10010 


COP2 Exception 










Other values 


Reserved. 



Referring now to Figure 12, a timing diagram 12 0 0 is 
shown illustrating the exception found signal generation 
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provided by the coprocessor interface 1012 of the present 
invention. 

Arithmetic instructions are dispatched by the CPU 1002 
during clock cycles 2, 3 and 5. These instructions are 
5 transferred to the coprocessor 1010 by assertion of the 
arithmetic strobe signal CPx_as_m during clock cycles 3, 4 
and 6, respectively. 

For each of the instructions A, B, and C, exception 
found signals must be generated by the coprocessor 1010 to 
10 inform the CPU 1002 either that no exception occurred for 
the instruction, or that an exception occurred, along with 
an indication of the type of exception. 

During clock cycle 4, the coprocessor interface 1012 
within the coprocessor 1010 asserts exception found strobe 
15 CP_excfs_m to indicate that a coprocessor exception signal 
is available on CP_excf_m. 

Also during clock cycle 4, the exception signal 
CP_excf_m is deasserted, thereby indicating that the oldest 
instruction for which an exception found signal has not 
20 been seen, in this case instruction A, did not generate an 
exception . 

During clock cycle 5, the coprocessor interface 1012 
within the coprocessor 1010 continues to assert exception 
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found strobe CP_excfs_m to indicate that a coprocessor 
exception found signal is available on CP_excf_m. 

Also during clock cycle 5, the exception signal 
CP_excf_m is deasserted, thereby indicating that the oldest 
instruction for which an exception found signal has not 
been seen, in this case instruction B, did not generate an 
exception. 

During clock cycle 8, the coprocessor interface 1012 
within the coprocessor 1010 asserts exception found strobe 
CP excfs_m to indicate that a coprocessor exception found 
signal is available on CP_excf_m. 

Also during clock cycle 8, the exception signal 
CP_excf_m is asserted, indicating that the oldest 
instruction for which an exception found signal has not 
been seen, in this case instruction C, did generate an 
exception. 

Furthermore, the coprocessor interface 1012 within the 
coprocessor 1010 generates an exception code on the signal 
group CP_exccode_m[4 : 0] , to indicate to the CPU 1002 what 
type of exception was generated by instruction C in the 
coprocessor. 
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Instruction Commit 

The coprocessor interface of the present invention 
provides signals for notifying the coprocessor when 
instructions can or cannot commit state. All instructions 
dispatched utilize this transfer so that the coprocessor 
knows when it can write back results for the instruction. 

Table 6 below provides a brief summary of the 
instruction commit signals that are provided within the COP 
interface of the present invention. Illustration of how 
these signals operate will be further described below with 
reference to Figure's 10 and 13. 



TABLE 6 



Signal Name 


Dir 


Issue 
Group 


Description 


CP_commits_m 


Out 


Comb, 
Arith, 
TF 


Coprocessor Commit Strobe. Asserted when commit 
signaling is available on CP_commit_m. 


CP_commit_m[1:0] 


Out 


Comb, 
Arith, 
TF 


Commit Coprocessor Instruction. Valid when 
CP_commits_m is asserted. 






CP_commit_m[1 :0] 


Type of Commit / Kill 








2'b00 


Instruction is not killed and can 
commit its results 








2'b01 








2'b10 


Instruction is killed, 
(not due to CP_excf_m) 








2'b11 


Instruction is killed 
(due to CP„excf_m) 
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Due to a variety of exceptional conditions, any 
instruction may need to be killed. The CPU 1002 contains 
logic that tells the coprocessor interface 1012 within the 
CPU 1002 when to commit or kill coprocessor instructions. 

Occasionally, a coprocessor instruction will be killed 
because of a coprocessor signaled exception. For example, 
if a floating point instruction is killed because of a 
floating point exception, the coprocessor must update 
exception status bits in the coprocessor's status register. 
On the other hand, if that same instruction was killed 
because of a higher-priority exception, those status bits 
must not be updated. For this reason, as part of the 
commit when signaling a kill, the CPU 1002 tells the 
coprocessor if the instruction was killed due to a 
coprocessor signaled exception or not. 

When a coprocessor arithmetic instruction is killed, 
all subsequent arithmetic instructions and To/From 
coprocessor data transfer instructions that have been 
dispatched are also killed. This is necessary because the 
killed instruction (s) may affect the operation of 
subsequent instructions. In the cycle in which an 

instruction is killed, other transfers may occur, but after 
that cycle, no further transfers occur for any of the 
killed instructions. A side-effect of this is that 
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instructions subsequent to a killed instruction do not have 
a commit transfer of their own. In effect, they are 
immediately killed and thus their remaining transfers 
cannot be sent, including their own commit transfer. 
Previously nullified instructions do not have a commit 
transfer either, because once nullified, no further 
transfers occur for that instruction. 

Referring to Figure 13, a timing diagram 1300 is 
provided to particularly illustrate the instruction commit 
mechanism in the coprocessor interface of the present 
invention. Arithmetic instructions A, B, and C are 
dispatched by the CPU 10 02 in clock cycles 2, 3, and 5, 
respectively. These instruction transfers are completed by 
the processor 1002 by assertion of the arithmetic strobe 
CPx_as_m during clock cycles 3, 4, and 6, respectively. 
Instruction commit information is then required for each of 
the instructions before the coprocessor is allowed to 
commit state. 

During clock cycle 4, the commit strobe signal 
CP_commits__m is asserted by the coprocessor interface 1012 
within the CPU 1002. This signal indicates that commit 
signaling is available on signal group CP_commit_m. Also 
during clock cycle 4, commit information is presented on 
signal group CP_commit_m by the coprocessor interface 1012 
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within the CPU 1002. The commit information presented on 
signal group CP_commit_m corresponds to the oldest 
instruction for which commit information has not yet been 
presented. In this case, the commit information 

5 corresponds to arithmetic instruction A. 

In cycles 5 and 8, commit information associated with 
instructions B and C is presented on signal group 
CP_commit_m. Depending on the values presented on the 
signal group by the coprocessor interface 1012, the 
10 coprocessor 1010 will either commit or kill the associated 
instruction, according to the signal values shown in Table 
6 . 

Miscellaneous Interface Signals 

Table 7 below provides operational information 
15 relating to coprocessor interface signals that have not yet 
been discussed, but whose understanding is not enhanced by 
reference to a timing diagram. 
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TABLE 7 



Signal Name 


Dir 


Issue 
Group 


Description 


CP_reset 


Out 


None 


Coprocessor Reset. Asserted when a hard or soft reset is 
performed by the CPU. At a minimum, this signal will be 
asserted for 1 cycle. 


CP_idle 


In 


None 


Coprocessor Idle. Asserted when the coprocessor logic is 
idle. Enables the integer processor core to go into sleep 
mode and shut down the internal integer processor core 
clock. Valid only if CP1_fppresent, CP1_mdmxpresent, or 
CPx_present is asserted. 


CP_tx32 


Sin 


None 


Coprocessor 32bit Transfers. When asserted, the 
integer unit must cause an Rl exception for 64bit TF 
instructions. Furthermore, wnen asseneu, ur i_jppreseru 
and CP1_mdmxpresent are ignored and internally 
deasserted. This forces CP_tx32 to only be used for 
COP2. This is a static input and must always be valid. 


CP1_fppresent 


Sin 


None 


Coprocessor FPU Present. Must be asserted when FPU 
hardware is connected to the coprocessor interface. 


CP 1 „mdmxpresent 


Sin 


None 


Coprocessor MDMX Present. Must be asserted when 
MDMX hardware is connected to the coprocessor interface. 


CPx_present 


Sin 


None 


Coprocessor Present. Must be asserted when 
coprocessor hardware is connected to the coprocessor 
interface. 


CP_irenable_m 


Out 


Comb, 
Arith, 
TF 


Enable Instruction Registering. When deasserted, no 
instruction strobes will be asserted in the following cycle. 
When asserted, there may be an instruction strobe 
asserted in the following cycle, instruction strooes mciuue 
CPx_as„m, CPx_ts_m, CPx_fs_m. 


CP_adisable_m 


Sin 


Comb, 
Arith 


Inhibit Arithmetic Dispatch. When asserted, prevents the 
CPU from dispatching an arithmetic instruction using this 
issue group. 


CP_tfdisable_m 


Sin 


Comb, 

TP 

i r 


Inhibit To/From Dispatch. When asserted, prevents the 
PPI 1 frnm Htenatrhinn a To/From instruction usinc. this 
issue group. 


CPJnst32_m 


Out 


Comb, 
Arith, 
TF 


MIPS32 Compatibility Mode - Instructions. When 
asserted, the dispatched instruction is restricted to the 
MIPS32 subset of instructions. Please refer to the MIPS64 
architecture specification available from MIPS 
Technologies, Inc. for a complete description of MIPS32 
compatibility mode. Valid the cycle before CPx_as_m, 
CPx_fs_m, or CPx_ts_m is asserted. 
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Signal Name 


Dir 


Issue 
Group 


Description 


CP_fr32_m 


Out 


Comb, 
Arith, 
TF 


MIPS32 Compatibility Mode - Registers. When 
asserted, the dispatched instruction uses the MIPS32 
compatible register file. Valid the cycle before CPx_as_m, 
CPx_ts_m, or CPx_fs_m is asserted. 


CP_endian_m 


Out 


Comb, 
Arith, 
TF 


Big Endian Byte Ordering. When asserted, the processor 
is using big endian byte ordering for the dispatched 
instruction. When deasserted, the processor is using little- 
endian byte ordering. Valid the cycle before CPx_as_m, 
CPx_ts_m, or CPx_fs_m is asserted. 



Various Issue Group Configurations 

A CPU that supports only single- issue integer 
instructions may implement a single combined issue group 
that can issue any type of instruction as follows: 

The issue group will be 0 (m=0) . 

CP_adisable_0 and CP__tf disable_0 may not be 
implemented. Since this is the only issue group, these 
instructions can never be disabled. 

CP order_0[2:0] may not be implemented. Since there 
is only one issue group, dispatch order is not needed. 

An integer core with this configuration can be used 
with a coprocessor with more issue groups. In this case, 
the Combined issue group of the coprocessor is connected to 
the combined issue group of the integer processor core and 
the other issue groups of the coprocessor are tied 
inactive . 
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An integer processor core that supports limited dual 
issue supports dual- issue of instructions only when one is 
an arithmetic coprocessor instruction and the other is a 
To/From coprocessor instruction. With this option, two 
5 issue groups will be implemented - one combined (issue 
group 0) and one arithmetic (issue group 1) . 

An integer core that supports full dual issue supports 
all the cases of limited dual issue, plus it can issue two 
arithmetic instructions or two To/From instructions. With 
10 this option, two combined issue groups will be implemented. 

A single-issue coprocessor can be used with a dual- 
issue integer processor core by simply connecting the 
combined issue groups together and asserting CP_adisable_l 
and CP_tfdisable_l for the 2 nd combined issue group of the 
15 integer processor core. 

A limited dual-issue coprocessor can be used with a 
dual-issue integer processor core by connecting the 
coprocessor combined issue group to one of the integer 
processor core's combined issue groups and asserting 
20 CP_adisable_m for that issue group. Then, connect the 
coprocessor's arithmetic issue group to the remaining 
combined issue group of the integer processor core and 
assert CP tfdisable_m for that issue group. 
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Although the present invention and its objects, 
features, and advantages have been described in detail, 
other embodiments are encompassed by the invention. In 
addition to implementations of the invention using 
5 hardware, the invention can be embodied in software 
disposed, for example, in a computer usable (e.g., 
readable) medium configured to store the software (i.e., a 
computer readable program code) . The program code causes 
the enablement of the functions or fabrication, or both, of 
10 the invention disclosed herein. For example, this can be 
accomplished through the use of general programming 
languages (e.g., C, C++, etc.), hardware description 
languages (HDL) including Verilog HDL, VHDL, AHDL (Altera 
Hardware Description Language) and so on, or other 
15 programming and/or circuit (i.e., schematic) capture tools 
available in the art. The program code can be disposed in 
any known computer usable medium including semiconductor 
memory, magnetic disk, optical disc (e.g., CD-ROM, DVD-ROM, 
etc.) and as a computer data signal embodied in a computer 
20 usable (e.g., readable) transmission medium (e.g., carrier 
wave or any other medium including digital, optical or 
analog-based medium) . As such, the code can be transmitted 
over communication networks including the Internet and 
intranets. It is understood that the functions 
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accomplished and/or structure provided by the invention as 
described above can be represented in a core that is 
embodied in program code and may be transformed to hardware 
as part of the production of integrated circuits. Also, 
the invention may be embodied as a combination of hardware 
and software. 

Furthermore, the particular illustrations used to 
describe the coprocessor interface of the present invention 
included a single CPU and a single coprocessor. However, 
as mentioned above, the coprocessor interface has been 
described to encompass connections between multiple CPU' s 
and multiple coprocessors, any of which may have single 
issue pipelines, or multiple issue pipelines. 

Also, although the coprocessor interface has been 
described with particular reference to MIPS32 and MIPS64 
Instruction Set Architecture, one skilled in the art will 
appreciate that the scalability, and configurability of the 
interface is not limited to such architecture, nor is it 
limited to the data width of the instructions, and/or the 
data that is being transferred. 

Finally, those skilled in the art should appreciate 
that they can readily use the disclosed conception and 
specific embodiments as a basis for designing or modifying 
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other structures for carrying out the same purposes of the 
present invention without departing from the spirit and 
scope of the invention as defined by the appended claims. 
We claim: 
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1 1. An interface for transferring data between a central 

2 processing unit (CPU) and a plurality of coprocessors, 

3 the interface comprising: 

4 an instruction bus, configured to transfer 

5 instructions to the plurality of coprocessors in 

6 an instruction transfer order, wherein particular 

7 instructions direct designated ones of the 

8 plurality of coprocessors to transfer the data 

9 to/from the CPU; and 

10 a data bus, coupled to said instruction bus, 

11 configured to subsequently transfer the data, 

12 wherein data order signals within said data bus 

13 prescribe a data transfer order that differs from 

14 said instruction transfer order. 

1 2. The interface as recited in claim 1 wherein the 

2 plurality of coprocessors comprises: 

3 a first plurality of floating-point coprocessors; or 

4 a first plurality of 3-D graphics accelerators; or 

5 a second plurality of floating-point coprocessors and 

6 a second plurality of 3-D graphics accelerators. 
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1 3. The interface as recited in claim 1, wherein said 

2 particular instructions comprise TO instructions, said 

3 TO instructions directing that the subsequent transfer 

4 of the data will be from the CPU to said designated 

5 ones of the plurality of coprocessors. 

1 4. The interface as recited in claim 3, wherein said 

2 particular instructions comprise FROM instructions, 

3 said FROM instructions directing that the subsequent 

4 transfer of the data will be to the CPU from said 

5 designated ones of the plurality of coprocessors. 

1 5. The interface as recited in claim 4, wherein said data 

2 bus comprises: 

3 data TO signals, for transferring data from the CPU to 

4 said designated ones of the plurality of 

5 coprocessors; and 

6 data FROM signals, for transferring data to the CPU 

7 from said designated ones of the plurality of 

8 coprocessors. 

1 6. The interface as recited in claim 5, wherein said data 

2 order signals comprise: 



64 



Docket MIPS : 0105. OOUS 



3 TO order signals, for prescribing said data transfer 

4 order with respect to transfers via said data TO 

5 signals; and 

6 FROM order signals, for prescribing said data transfer 

7 order with respect to transfers via said data 

8 FROM signals. 

1 7. The interface as recited in claim 6, wherein said TO 

2 order signals prescribe a particular outstanding TO 

3 instruction relative to all outstanding TO 

4 instructions. 

1 8. The interface as recited in claim 6, wherein said FROM 

2 order signals prescribe a particular outstanding FROM 

3 instruction relative to all outstanding FROM 

4 instructions. 

1 9. The interface as recited in claim 1 wherein said data 

2 bus transfers the data in parallel to one of said 

3 designated ones of the plurality of coprocessors, said 

4 one of said designated ones of the plurality of 

5 coprocessors having multiple issue pipelines providing 

6 for parallel instruction execution. 

1 10. A computer program product for use with a computing 

2 device, the computer program product comprising: 
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3 a computer usable medium, having computer readable 

4 program code embodied in said medium, for causing 

5 a coprocessor interface to be described that 

6 transfers data between CPU and a plurality of 

7 coprocessors, said computer readable program code 

8 comprising: 

9 first program code, for providing an instruction 

10 bus, said instruction bus configured to 

11 transfer instructions to said plurality of 

12 coprocessors in an instruction transfer 

13 order, wherein particular instructions 

14 direct designated ones of the plurality of 

15 coprocessors to transfer said data to/from 

16 said CPU; and 

17 second program code, for providing a data bus, 

18 said data bus configured to subsequently 

19 transfer said data, wherein data order 

20 signals within said data bus prescribe a 

21 data transfer order that is different from 

22 said instruction transfer order. 

1 11. The computer program product as recited in claim 10, 

2 wherein said particular instructions comprise: 
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3 TO instructions, said TO instructions directing that 

4 the subsequent transfer of said data will be from 

5 said CPU to said designated ones of said 

6 plurality of coprocessors; and 

7 FROM instructions, said FROM instructions directing 

8 that the subsequent transfer of said data will be 

9 to said CPU from said designated ones of said 
10 plurality of coprocessors. 

1 12. The computer program product as recited in claim 11, 

2 wherein said data order signals comprise: 

3 TO order signals, for specifying said data transfer 

4 order for a particular outstanding TO instruction 

5 relative to all outstanding TO instructions; and 

6 FROM order signals, for specifying said data transfer 

7 order for a particular outstanding FROM 

8 instruction relative to all outstanding FROM 

9 instructions. 

1 13. The computer program product as recited in claim 10, 

2 data bus is configured to transfer said data in 

3 parallel to particular coprocessors that have multiple 

4 issue pipelines providing for parallel instruction 

5 execution and corresponding data transfers. 
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A computer data signal embodied in a transmission 
medium, the computer data signal comprising: 

computer- readable first program code, for providing an 
instruction bus for transferring instructions to 
a plurality of coprocessors in an instruction 
transfer order, wherein particular instructions 
direct particular coprocessors to transfer data 
to/from a CPU; and 

computer-readable second program code, for providing a 
data bus for subsequently transferring said data, 
wherein data order signals within said data bus 
prescribe a data transfer order that differs from 
said instruction transfer order. 

The computer data signal as recited in claim 14, 
wherein said particular instructions comprise TO 
instructions, said TO instructions directing that 
subsequent transfer of said data will be from said CPU 
to said particular coprocessors. 

The computer data signal as recited in claim 15, 
wherein said particular instructions comprise FROM 
instructions, said FROM instructions directing that 
the subsequent transfer of said data will be to said 
CPU from said particular coprocessors. 
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1 17. The computer data signal as recited in claim 14, 

2 wherein said data bus comprises: 

3 data TO signals, for transferring data from said CPU 

4 to said particular coprocessors; and 

5 data FROM signals, for transferring data to said CPU 

6 from said particular coprocessors. 

1 18. The computer data signal as recited in claim 17, 

2 wherein said data order signals comprise: 

3 TO order signals, for prescribing said data transfer 

4 order with respect to transfers via said data TO 

5 signals; and 

6 FROM order signals, for prescribing said data transfer 

7 order with respect to transfers via said data 

8 FROM signals. 

1 19. The computer data signal as recited in claim 18, 

2 wherein said TO order signals prescribe a particular 

3 outstanding TO instruction relative to all outstanding 

4 TO instructions. 

1 20. The computer data signal as recited in claim 18, 

2 wherein said FROM order signals prescribe a particular 

3 outstanding FROM instruction relative to all 

4 outstanding FROM instructions. 
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1 21. The computer data signal as recited in claim 1 wherein 

2 said data bus transfers said data in parallel to 

3 selected coprocessors, said selected coprocessors 

4 having multiple issue execution pipelines. 

1 22. A method for transferring data between a CPU and a 

2 plurality of coprocessors, the method comprising: 

3 a) transmitting instructions to the plurality 

4 coprocessors, each of the instructions directing 

5 a data transfer between the CPU and a specific 

6 coprocessor, wherein said transmitting is 

7 provided in a specific instruction order; 

8 b) subsequently transferring the data in an order 

9 different from the specific instruction order, 

10 said transferring comprising: 

11 i) prescribing transfer of a data element 

12 corresponding to a specific outstanding 

13 instruction relative to all outstanding 

14 instructions, the outstanding instructions 

15 being those instructions that have not 

16 completed a subsequent data transfer. 

1 22. The method as recited in claim 21, said transmitting 

2 comprises: 
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3 i) issuing a plurality of the instructions in parallel 

4 to the specific coprocessor; and 

5 ii) designating an execution order corresponding to 

6 said issuing. 
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